iT邦幫忙

2023 iThome 鐵人賽

DAY 13
0
Modern Web

React 測試 x AI:探索測試新境界,測試不再枯燥乏味!系列 第 13

[Day 13] React + Jest 彈窗測試 (AI)

  • 分享至 

  • xImage
  •  

copilot chat 的部分一樣依照兩個檔案分別做測試

ModalPage 頁面測試

頁面測試需要給他 ModalContext.provider 的 value 值,並請他使用在 ./data/modal.data 裡面的資料來進行判斷。

/tests mock openModal use ModalContext.provider. The value type is

{
isOpen: boolean;
openModal: (text?: string) => void;
closeModal: () => void;
content: string;
};

and the text use the data in ./data/modal.data

copilot chat

Modal 元件測試

元件測試一樣請他模擬 closeModal() 函式,不過因為還要測試彈窗內容顯示是否正確,所以這邊直接跟他說給我兩個測試案例,一個是模擬 closeModal() 函式,另一個是測試彈窗內容是否正確。

/tests two test case

  1. mock closeModal use ModalContext.provider. The value type is
   {
   isOpen: boolean;
   openModal: (text?: string) => void;
   closeModal: () => void;
   content: string;
   };
  1. test content correct

copilot chat

結論

像使用外部的 useContext() 做測試時,需要提供完整的 value 內容,才能讓測試順利進行,因為前面有提過 copilot chat 只會根據當前打開的檔案進行分析,所以只要測試需要使用到當前檔案以外的資料時,都需要事先提供給 copilot chat,這樣他才能幫你產生正確的程式碼。


上一篇
[Day 12] React + Jest 彈窗測試
下一篇
[Day 14] React + Jest API 測試
系列文
React 測試 x AI:探索測試新境界,測試不再枯燥乏味!30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言